﻿using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using AccesoDatos.Objetos;
using AccesoDatos.Manejador;

namespace Autorizacion_facturas_caja.Vacaciones
{
    public partial class frmVacaciones_Busqueda_Reporte_Vacaciones : Form
    {
        Manejador_Empleado_Captura Mane = new Manejador_Empleado_Captura();
        objRH obj = new objRH();
        objVacaciones obj1 = new objVacaciones();
        Manejador_Vacaciones MV = new Manejador_Vacaciones();

        #region FUNCIONES
        //coloca la fecha inicio 15 dias antrasada
        private void fecha()
        {
            DateTime Fecha_Hoy = DateTime.Today;

            Fecha_Hoy = Fecha_Hoy.AddDays(-15);
            dTPInicio.Text = Fecha_Hoy.ToShortDateString();
        }

        //realiza la busqueda de los empleados
        private void buscar()
        {
            if (cmbCompletado.Text.Trim() != "")
            {
                obj.Buscar = txtBuscar.Text.Trim();
                obj1.Completado = cmbCompletado.Text;
                obj.SucId = cmbSucursal.SelectedValue.ToString();
                obj1.Fecha_Inicio_Vacaciones = dTPInicio.Value;
                obj1.Fecha_fin_vacaciones = dTPFin.Value;
                dataGridView1.DataSource = MV.ListaParaReporteHistorial(obj.Buscar, obj1.Completado, obj.SucId, obj1.Fecha_Inicio_Vacaciones, obj1.Fecha_fin_vacaciones);
                propiedadesColumnas();
            }
            else { MessageBox.Show("SELECCIONE EL ATRIBUTO PARA LA BUSQUEDA", "ALERTA"); }
        }

        //Obtiene los datos de la tabla cat_sucursales al combo de sucursales
        private void ObtieneDatosCombo()
        {
            cmbSucursal.DataSource = Mane.ObtieneSucursales();
            cmbSucursal.ValueMember = "SucId";
            cmbSucursal.DisplayMember = "Nombre";
        }

        //propiedades de las columnas
        private void propiedadesColumnas()
        {
            this.dataGridView1.RowHeadersVisible = false;

            /*Esconde las columnas*/
            this.dataGridView1.Columns["id_empleado"].Visible = false;
            this.dataGridView1.Columns["nombre"].Visible = false;
            this.dataGridView1.Columns["apellidos"].Visible = false;


            //Renombra columnas

            this.dataGridView1.Columns["departamento"].HeaderText = "DEPARTAMENTO";
            this.dataGridView1.Columns["empresa"].HeaderText = "EMPRESA";
            this.dataGridView1.Columns["fecha_ingreso"].HeaderText = "FECHA INGRESO";
            this.dataGridView1.Columns["puesto"].HeaderText = "PUESTO";
            this.dataGridView1.Columns["Nombre_apellidos"].HeaderText = "EMPLEADO";
            this.dataGridView1.Columns["Nombre_apellidos"].DisplayIndex = 0;
            this.dataGridView1.Columns["departamento"].HeaderCell.Style.Alignment = DataGridViewContentAlignment.MiddleCenter;
            this.dataGridView1.Columns["empresa"].HeaderCell.Style.Alignment = DataGridViewContentAlignment.MiddleCenter;
            this.dataGridView1.Columns["fecha_ingreso"].HeaderCell.Style.Alignment = DataGridViewContentAlignment.MiddleCenter;
            this.dataGridView1.Columns["puesto"].HeaderCell.Style.Alignment = DataGridViewContentAlignment.MiddleCenter;
            this.dataGridView1.Columns["Nombre_apellidos"].HeaderCell.Style.Alignment = DataGridViewContentAlignment.MiddleCenter;
            this.dataGridView1.Columns["fecha_ingreso"].DefaultCellStyle.Alignment = DataGridViewContentAlignment.MiddleCenter;
        }
        #endregion

        #region BOTONES
        //llama al metodo buscar
        private void btnBuscar_Click(object sender, EventArgs e)
        {
            buscar();
        }

        //cierra la forma
        private void btnRegresar_Click(object sender, EventArgs e)
        {
            Close();
        }


        #endregion

        #region  EVENTOS
        //llama metodos
        public frmVacaciones_Busqueda_Reporte_Vacaciones()
        {
            InitializeComponent();
            ObtieneDatosCombo();
            fecha();
        }

        //despliega el reporte
        private void dataGridView1_CellContentClick(object sender, DataGridViewCellEventArgs e)
        {
            if (e.ColumnIndex != 0 && e.RowIndex >= 0)
            {
                obj.Id_Empleado = Convert.ToInt32(dataGridView1[0, e.RowIndex].Value);
                frmVacaciones_Reporte_Empleado_Historial form = new frmVacaciones_Reporte_Empleado_Historial(obj, obj1, cmbSucursal.Text);
                form.ShowDialog();
                buscar();
            }
        }

        //valida las fechas 
        private void dTPInicio_ValueChanged(object sender, EventArgs e)
        {
            if (dTPInicio.Value > dTPFin.Value)
            {
                dTPInicio.Value = DateTime.Today;
                MessageBox.Show("FECHA INCORRECTA", "ALERTA");
            }
        }

        //mensajes de los botones y date timers
        private void frmVacaciones_Busqueda_Reporte_Vacaciones_Load(object sender, EventArgs e)
        {
            toolTip1.SetToolTip(btnBuscar, "BUSCAR");
            toolTip1.SetToolTip(btnRegresar, "REGRESAR");
            toolTip1.SetToolTip(dTPInicio, "FECHA DE INICIO DE VACACIONES");
            toolTip1.SetToolTip(dTPFin, "FECHA FIN DE VACACIONES");
        }

        //valida las fechas 
        private void dTPFin_ValueChanged(object sender, EventArgs e)
        {
            if (dTPInicio.Value > dTPFin.Value)
            {
                dTPFin.Value = DateTime.Today;
                MessageBox.Show("FECHA INCORRECTA", "ALERTA");
            }
        }

        //llama al metodo buscar
        private void txtBuscar_TextChanged(object sender, EventArgs e)
        {
            buscar();
        }
        #endregion
 
    }
}
